package com.accelstack.cmp.repository;

import com.accelstack.cmp.entity.Server;
import com.accelstack.cmp.enums.ServerStatus;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * 服务器Repository
 */
@Repository
public interface ServerRepository extends JpaRepository<Server, Long> {
    
    /**
     * 根据数据中心ID查询服务器列表
     */
    List<Server> findByDatacenterId(Long datacenterId);
    
    /**
     * 根据机架ID查询服务器列表
     */
    List<Server> findByRackId(Long rackId);
    
    /**
     * 根据状态查询服务器列表
     */
    List<Server> findByStatus(ServerStatus status);
    
    /**
     * 查询服务器（包含数据中心和机架信息）
     */
    @Query("SELECT s FROM Server s LEFT JOIN FETCH s.datacenter LEFT JOIN FETCH s.rack WHERE s.id = :id")
    Server findByIdWithRelations(@Param("id") Long id);
}

